home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
CU Amiga Super CD-ROM 15
/
CU Amiga Magazine's Super CD-ROM 15 (1997)(EMAP Images)(GB)[!][issue 1997-10].iso
/
CUCD
/
Graphics
/
Ghostscript
/
source
/
files.h
< prev
next >
Wrap
C/C++ Source or Header
|
1996-04-20
|
5KB
|
138 lines
/* Copyright (C) 1989, 1995, 1996 Aladdin Enterprises. All rights reserved.
This file is part of Aladdin Ghostscript.
Aladdin Ghostscript is distributed with NO WARRANTY OF ANY KIND. No author
or distributor accepts any responsibility for the consequences of using it,
or for whether it serves any particular purpose or works at all, unless he
or she says so in writing. Refer to the Aladdin Ghostscript Free Public
License (the "License") for full details.
Every copy of Aladdin Ghostscript must include a copy of the License,
normally in a plain ASCII text file named PUBLIC. The License grants you
the right to copy, modify and redistribute Aladdin Ghostscript, but only
under certain conditions described in the License. Among other things, the
License requires that the copyright notice and this notice be preserved on
all copies.
*/
/* files.h */
/* Common declarations for zfile.c and zfileio.c */
/* Requires stream.h */
/*
* In many places below, a do {...} while (0) avoids problems with a possible
* enclosing 'if'.
*/
/*
* File objects store a pointer to a stream in value.pfile.
* A file object is valid if its "size" matches the read_id or write_id
* (as appropriate) in the stream it points to. This arrangement
* allows us to detect closed files reliably, while allowing us to
* reuse closed streams for new files.
*/
#define fptr(pref) (pref)->value.pfile
#define make_file(pref,a,id,s)\
make_tasv(pref,t_file,a,id,pfile,s)
/* The stdxxx files. We have to access them through procedures, */
/* because they might have to be opened when referenced. */
int zget_stdin(P1(stream **));
int zget_stdout(P1(stream **));
int zget_stderr(P1(stream **));
extern bool gs_stdin_is_interactive;
/* An invalid (closed) file. */
extern stream *invalid_file_entry;
/* Macros for checking file validity. */
#define file_is_valid(svar,op)\
(svar = fptr(op), (svar->read_id | svar->write_id) == r_size(op))
#define check_file(svar,op)\
do\
{ check_type(*(op), t_file);\
if ( !file_is_valid(svar, op) ) return_error(e_invalidaccess);\
}\
while (0)
/*
* If a file is open for both reading and writing, its read_id, write_id,
* and stream procedures and modes reflect the current mode of use;
* an id check failure will switch it to the other mode.
*/
int file_switch_to_read(P1(const ref *));
#define check_read_file(svar,op)\
do\
{ check_read_type(*(op), t_file);\
check_read_known_file(svar, op, return);\
}\
while (0)
#define check_read_known_file(svar,op,error_return)\
check_read_known_file_else(svar, op, error_return, svar = invalid_file_entry)
/* The do... avoids problems with a possible enclosed 'if'. */
#define check_read_known_file_else(svar,op,error_return,invalid_action)\
do\
{ svar = fptr(op);\
if ( svar->read_id != r_size(op) )\
{ if ( svar->read_id == 0 && svar->write_id == r_size(op) )\
{ int fcode = file_switch_to_read(op);\
if ( fcode < 0 ) error_return(fcode);\
}\
else do { invalid_action; } while (0); /* closed or reopened file */\
}\
}\
while (0)
int file_switch_to_write(P1(const ref *));
#define check_write_file(svar,op)\
do\
{ check_write_type(*(op), t_file);\
check_write_known_file(svar, op, return);\
}\
while (0)
#define check_write_known_file(svar,op,error_return)\
do\
{ svar = fptr(op);\
if ( svar->write_id != r_size(op) )\
{ int fcode = file_switch_to_write(op);\
if ( fcode < 0 ) error_return(fcode);\
}\
}\
while (0)
/* Data exported by zfile.c. */
/* for zfilter.c and ziodev.c */
extern const uint file_default_buffer_size;
/* Procedures exported by zfile.c. */
/* for gs.c */
FILE *lib_fopen(P1(const char *));
/* for gsmain.c */
int lib_file_open(P6(const char *, uint, byte *, uint, uint *, ref *));
/* for iccinit.c */
int file_read_string(P3(const byte *, uint, ref *));
/* for os_open in ziodev.c */
#ifdef iodev_proc_fopen /* in gxiodev.h */
int file_open_stream(P6(const char *, uint, const char *, uint,
stream **, iodev_proc_fopen_t));
#endif
/* for zfilter.c */
int filter_open(P6(const char *, uint, ref *, const stream_procs _ds *,
const stream_template *, const stream_state *));
/* for zfileio.c */
void make_stream_file(P3(ref *, stream *, const char *));
/* for ziodev.c */
int file_close_finish(P1(stream *));
int file_close_disable(P1(stream *));
int file_close_file(P1(stream *));
/* for gsmain.c, interp.c */
int file_close(P1(ref *));
/* for ziodev.c */
stream *file_alloc_stream(P2(gs_memory_t *, client_name_t));
/* for isave.c */
void file_save(P0());
/*void file_restore(P1(const alloc_save_t *));*/
/* Procedures exported by zfileio.c. */
/* for ziodev.c */
int zreadline_from(P5(stream *, byte *, uint, uint *, bool *));